<?php

namespace app\admin\model;

use think\Db;
use think\Model;


class Projectgongsi extends Model
{

    

    

    // 表名
    protected $name = 'projectgongsi';
    
    // 自动写入时间戳字段
    protected $autoWriteTimestamp = 'integer';

    // 定义时间戳字段名
    protected $createTime = 'createtime';
    protected $updateTime = 'updatetime';
    protected $deleteTime = false;

    // 追加属性
    protected $append = [
        'status_text',
        'cate_text',
        'area_text',
    ];

    public function getCateTextAttr($val,$data){
        $cate = Db::table('fa_yalimedia_teacher_cate')->find($data['cate_id']);
        return $cate?$cate['name']:'';
    }

    public function getAreaTextAttr($val,$data){
        $ids = explode(',',$data['area_id']);
        $cate = Db::table('fa_city')->where('id','in',$ids)->select();
        $str = '';
        if($cate){
           $arr =  array_column($cate,'name');
           $str = implode(',',$arr);
        }
        return $str;
    }



    public function getStatusList()
    {
        return ['0' => __('Status 0'), '1' => __('Status 1')];
    }


    public function getStatusTextAttr($value, $data)
    {
        $value = $value ? $value : (isset($data['status']) ? $data['status'] : '');
        $list = $this->getStatusList();
        return isset($list[$value]) ? $list[$value] : '';
    }




    public function expert()
    {
        return $this->belongsTo('Expert', 'expert_ids', 'id', [], 'LEFT')->setEagerlyType(0);
    }
}
